|      | NATIONAL INSTITUTE OF TECHNOLOGY SILCHE | 11 |
|------|-----------------------------------------|----|
|      | CACHAR, ASSAM                           |    |
|      |                                         |    |
|      |                                         |    |
|      |                                         |    |
|      |                                         |    |
|      | LABORATORY EXCERCISE BOOK               |    |
|      | LABORATORY EXCERCISE DOR                |    |
|      |                                         |    |
|      |                                         |    |
|      | BOTECHO SEM.                            |    |
|      |                                         |    |
|      |                                         |    |
| ,    | NAME: SUBHOTIT GHIMIRE                  | _  |
| z == | SCH. TD.: 1912160                       | _  |
|      | BRANCH: C.S.E B                         | _  |
|      | SUBJECT: MICROPROCESSOR LAB             |    |
|      | CODE: EE224                             |    |
|      |                                         | _  |
|      |                                         | _  |
|      |                                         |    |
|      |                                         |    |
|      |                                         |    |
|      |                                         |    |
|      |                                         |    |
|      |                                         |    |
|      |                                         |    |
|      |                                         |    |
|      |                                         |    |
|      |                                         | _  |

| → ×1                                  |           | 40 Vec (+5V)        |  |  |  |
|---------------------------------------|-----------|---------------------|--|--|--|
| → ×2                                  |           | 39 HOLD <           |  |  |  |
| < 0\r                                 | <u> </u>  | 38 HLDA-            |  |  |  |
| ← <b>5</b> 0D                         | , 🗀 4     | 37 _ CLK (OUT)-     |  |  |  |
| <b>→</b> ST0                          | 5         | 36 ☐ RESET IN ←     |  |  |  |
| → TRAF                                | 6         | 35 READY Z          |  |  |  |
| → RST 7.5                             | 5 L 7     | 34 IOIM ->          |  |  |  |
| → RST 6.5                             | <b>8</b>  | 33 S <sub>1</sub> > |  |  |  |
| → RST 5.5                             | Д 3       | 32 □ RD>            |  |  |  |
| → INTR                                | ±0 8085 A | 31 WR ->            |  |  |  |
| ← INTA                                | 77        | 30 ALE              |  |  |  |
| $\longleftrightarrow$ AD <sub>o</sub> | <b></b>   | 29 S>               |  |  |  |
| $\longleftrightarrow AD_{L}$          | 73        | 28 A15              |  |  |  |
| $\longleftrightarrow AD_2$            | <u></u>   | 27 A14 ->           |  |  |  |
| $\leftrightarrow AD_3$                | 15        | 26 A13              |  |  |  |
| <→ AD.                                | 76        | 25 A12 ->           |  |  |  |
| $\leftrightarrow$ AD,                 | 7.7       | 24 Au ->            |  |  |  |
| ← AD                                  | 6 /8      | 23 A10 ->           |  |  |  |
| ←→ AD                                 | 2 7 9     | 22 As               |  |  |  |
| (GND) VSS                             | 20        | 21   A8>            |  |  |  |
|                                       |           |                     |  |  |  |

|     | EXPLANATION OF 8085 MP PINS:                          |
|-----|-------------------------------------------------------|
|     |                                                       |
| 7.  | A8-A15 (Omput): These are address bus and used for    |
|     | the most significant bits of the memory address.      |
|     |                                                       |
| ۵.  | ADO - ADA (Input/Output): These are time multiplexed  |
|     | address data bus and are used for the least           |
|     | significant 8 bits of the memory address during the   |
|     | first clock cycle and then for data during the        |
|     | second and third clock cycles.                        |
| 1)* | x / y y y y y y y y y y y y y y y y y y               |
| 3.  | ALE (Address Latch Enable): It goes high during the   |
|     | 1st clock cycle of a machine It enables the           |
|     | lower 8 bits of the address to be latched             |
|     | either in the memory or external latch.               |
| 2   |                                                       |
| 4.  | TOIM: It is a status signal; when it goes high.       |
|     | the address on the address bus is for IIO device,     |
|     | otherwise for memory.                                 |
|     |                                                       |
| 5.  |                                                       |
|     | types of operation.                                   |
|     | RD (Output): It is used to control read signal.       |
| 6   | KI) (output) 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2    |
| 7.  | WR (Output): It is used to control write operation    |
| 4.  |                                                       |
| 努.  | HOLD (Input): It is used to indicate that another     |
|     | device is requesting the use of address and data bug. |
|     | , ,                                                   |
|     |                                                       |

| 9.     | HLDA (Output): It is an acknowledgement signal                                                  |
|--------|-------------------------------------------------------------------------------------------------|
|        | used to indicate HOLD request has been received.                                                |
| 10,    | INTR (Input): When it goes high, the microprocessor suspends its normal sequence of operations. |
|        | suspends its normal sequence of operations.                                                     |
| - 77 · | INTA (Output): It is an impart interrupt acknowledge                                            |
|        | ment signal sent by MP after INTR is received.                                                  |
| 12.    | RST 5.5, 6.5, 7.5 and TRAP: These are various                                                   |
|        | interrupt signals. Here, TRAP has the highest priority.                                         |
| 13.    | RESET IN (Input): It recets the PC to zero.                                                     |
| 14.    | RESET OUT (Output): It indicates CPU being reset.                                               |
| 15.    |                                                                                                 |
| - 3    | produce 2 suitable check for operation of the MP.                                               |
| 76.    | Cir (Output): It is clock output for the uses.                                                  |
|        | Its frequency is same at which processor operates.                                              |
| 7.4    | SID (Input): It is used for data lines for serial input.                                        |
| 78,    | SOD (Output): It is used for data line for serial output                                        |
| 73.    | Vcc: It is the +5 volts supply.                                                                 |
|        | •                                                                                               |
| 20.    | Vcs: It is a ground reference                                                                   |

|   | AIM: ADDITION OF TWO 8-BIT NUMBERS                      |
|---|---------------------------------------------------------|
|   |                                                         |
|   | THEORY:                                                 |
|   | THE COLOR                                               |
|   | 1. ORG Address (ORIGIN) Directive reserves the starting |
|   | address for Program Code or data in specified           |
|   | memory sirray.                                          |
|   | 2. LXI H (LOAD ADDRESS PAIR IMMEDIATELY) LOAds 16- bit  |
|   | data in register pair designated by operand.            |
|   | 3. MOV A, M (MOVEM TO A) copies the data type           |
|   | into accumulator from the memory specified by           |
|   | the address in H-L pair.                                |
|   | 4. MUI (MOVE IMMEDIATE DATA) moves immediate value      |
|   | to specified register.                                  |
|   | 5. INR R (INCREMENT REGISTER) increment the specified   |
|   | register content by 1.                                  |
|   | 6. INX HITNCREMENT REGISTER PAIR) increments the        |
|   | contents of the register pair by one.                   |
|   | 7. ADD M (ADDITION) adds the contents of memory         |
|   | to samulator.                                           |
|   | 8. RST 1 (RESET) finishes the enecution of the          |
| _ | current instruction and stops any further execution     |
|   | 9. DB (DEFINE BYTE) Directives defined to store values  |
|   | in specified memory 87723.                              |
|   |                                                         |
|   |                                                         |
| _ |                                                         |
| _ |                                                         |
|   |                                                         |

## FLOW CHART:

START

Initialize Memory Register by loading content in HL

Load first number into Accumulator

Increment He pair for next number

Add accumulator with M. Reg.

Increment HL pair for M. Reg. initialisation

tood accumulator result into Mikeg Location

HALT

PROGRAM:

#ORG TOOOH

| Meniory Address | Mnemonics | Commente                         | Hencoc |
|-----------------|-----------|----------------------------------|--------|
| 7000            | LXI H,    | Get address of 1st no. in HLpair | - 21   |
| 7001            | 1         |                                  | ΟZ     |
| 7002            |           |                                  | 75     |
| 7003            | MOV A,M   | Move number into accumulator     | 7E     |
| 7004            | HXMI      | HL points address                | 23     |
|                 |           |                                  | 00     |

7005 ADDM Add the 2nd number 86 7006 INXH HI points 23

7007 MOV M.A Store result in 77
7008 RST 1 Terminate CF

#ORG 75014 Store input at the address

#DB12H, 13H Get two 8 bit no. in successive location



| AIM: SUBTRACTION OF TWO 8-BIT NUMBERS AND TWO.           |
|----------------------------------------------------------|
|                                                          |
| THEORY:                                                  |
| 1. ORG Address Directive reserves the starting code      |
| address for Program Code or data in specified memory     |
| zirza                                                    |
| 2. LXI H loads L6 bit data in register pair designated   |
| by operand.                                              |
| 3. LHILD Address (LOAD HI PAIR DIRECT) loads 16 bit date |
| from specified address to designate in register pair.    |
| 4. MOV A, M copies data byte into accumulator from the   |
| memory specified by the address in HL pair.              |
| 5. MUI moves immediate value to specified register.      |
| 6. SBB instruction subtracts specified register content  |
| and carry flag to Accumulator and stores                 |
| result in the Accumulator.                               |
| 7. INC Address instruction jumps the enecution to        |
| the specified Address if carry flag is reset.            |
| 8. INR instruction increments specified register content |
| by 1 value                                               |
| 9. INX H increments contents of register pair by I       |
| 10. SUB M subtracts contents of register to accumulator  |
| 11. STH address copies the contents of the accumulator   |
| to the memory location specified in the instruction      |
| 12. SHLD Address instruction stores HL pair content      |
| to specified address.                                    |
| 13. RSTI finishes the execution of the current           |
| instruction and stops further enecution.                 |
|                                                          |

|                                         | FLOWCHA                      | rRT:                                                | 8                                    |                                        |  |  |  |  |  |
|-----------------------------------------|------------------------------|-----------------------------------------------------|--------------------------------------|----------------------------------------|--|--|--|--|--|
|                                         |                              | (\$                                                 | TART                                 |                                        |  |  |  |  |  |
|                                         |                              |                                                     |                                      |                                        |  |  |  |  |  |
|                                         | in Posistertos lasdino cente | ent in HI                                           |                                      |                                        |  |  |  |  |  |
|                                         | Sv                           | Initialize Memory Register by loading content in HL |                                      |                                        |  |  |  |  |  |
|                                         |                              | Load Escal                                          | num from memory to accumu            | lator                                  |  |  |  |  |  |
|                                         | -                            | Coast Just                                          | Many from Memory to seed to          |                                        |  |  |  |  |  |
|                                         |                              | Tarana                                              | nt HL pair for next num              | her                                    |  |  |  |  |  |
|                                         |                              | 1 NOVE INC                                          | The pair yet the set them            |                                        |  |  |  |  |  |
| n .                                     | Suk                          | Subtract M Register content to accumulator          |                                      |                                        |  |  |  |  |  |
|                                         | 2 2                          |                                                     |                                      |                                        |  |  |  |  |  |
| Increment HL pair to initialise M. Reg. |                              |                                                     |                                      |                                        |  |  |  |  |  |
|                                         |                              |                                                     |                                      | —————————————————————————————————————— |  |  |  |  |  |
|                                         | Accumulator result to M      | Req.                                                |                                      |                                        |  |  |  |  |  |
|                                         |                              | 4                                                   |                                      | 7                                      |  |  |  |  |  |
|                                         |                              | * y = * 3                                           | END                                  |                                        |  |  |  |  |  |
| *                                       |                              |                                                     |                                      |                                        |  |  |  |  |  |
|                                         | PROGRAM                      | 1 (Subtracti                                        | in of two 8-bit number               | ers)                                   |  |  |  |  |  |
|                                         | Address                      | Mnemonics                                           | Comment                              | Hencode.                               |  |  |  |  |  |
|                                         |                              | #ORG 7000H                                          |                                      |                                        |  |  |  |  |  |
|                                         | 7000                         | LXI H, 7501                                         | 11 Get address of Let no. in HI pair | 21                                     |  |  |  |  |  |
|                                         | 7001                         | -                                                   |                                      | OT                                     |  |  |  |  |  |
|                                         | 7002                         |                                                     |                                      | 75                                     |  |  |  |  |  |
|                                         | 7003                         | MOV A, M                                            | 1 Move no. into accumulator          | 7E                                     |  |  |  |  |  |
|                                         | 7004                         | H XNI                                               | 11 HL points to 7502 H               | 23                                     |  |  |  |  |  |
|                                         | 7005                         | SBB M                                               | 11 Subtract 2nd na from 1st no.      | 9E                                     |  |  |  |  |  |
| 4.5                                     | 7606                         | TNX H                                               | 11 HL points to 7508H                | 23                                     |  |  |  |  |  |
|                                         | 11                           | 1                                                   |                                      |                                        |  |  |  |  |  |

11 move contents of acc. to memory

7007

MOV M,A

| 7008 | RST 1      | 11 Terminate                                 | CF |
|------|------------|----------------------------------------------|----|
|      | HORG 7501H | 11 Store no. at address                      |    |
|      | #DB 20,10  | 11 Get two 8 bit no. at successive locations |    |

## PROGRAM (Subtraction of two 16- bit numbers)

| Address | Mnemonics        | Comments                                        | Hexade        |
|---------|------------------|-------------------------------------------------|---------------|
|         | #ORG 7000H       |                                                 |               |
| 7000    | THID 3007        | 11 Get 1st 16 bit no. in HL Pair                | 2A            |
| 7001    |                  |                                                 | OΓ            |
| 7002    | 2                |                                                 | 75            |
| 7003    | XCHG             | 11 Exchange HL pair with DE                     | EB            |
| 7004    |                  | 11 Get 2nd 16 bit no. in HL pair.               | 2A            |
| 7005    |                  |                                                 | 03            |
| 7006    |                  |                                                 | 75            |
| 7007    | MOV A, E         | Il Get lower byte of Lot number                 | 78            |
| 7008    |                  | Il Subtract lower byte of 2nd number.           | 22            |
| 7009    | MOV LA           | 11 Store the result in req. L.                  | 6F            |
| 700A    |                  | Il Get higher byte of 1st number.               | <del>20</del> |
| 7008    | SBB H            | 11 Subtract higher byte of 2nd no. with bonon   | 3c            |
| 700c    | MOV H, A         | 2                                               | 67            |
| 7000    |                  | 1 Store 16 bit result 2t 7505 H 87506H          | 22            |
| 700E    |                  |                                                 | 05            |
| 700F    |                  |                                                 | 75            |
| 7010    | RST L            | 11 Terminate                                    | CF            |
|         | #08G7501H        | 11 Stores inputs at the address                 |               |
|         | #DB 30.40 .10.20 | 11 Get two 16 bit nos. from successive location |               |

## RESULT:

for subtraction of two bit 8-bit numbers,

INDUT - 7501 - 20H; 7502-10H





for subtraction of two-16-bit numbers,

TNPUT - 7501-30H; 7502-40H

7503-10H; 7504-20H

OUTPUT - 7505-20H

7506-20H

for subtraction of two - 16-bit numbers,

